It's now handled by the color pipeline.
gsk_vulkan_push_constants_init (GskVulkanPushConstants *constants,
const graphene_matrix_t *mvp)
{
- GdkRGBA transparent = { 0, 0, 0, 0 };
-
gsk_vulkan_push_constants_set_mvp (constants, mvp);
- gsk_vulkan_push_constants_set_color (constants, &transparent);
}
void
gsk_vulkan_push_constants_set_mvp (self, &new_mvp);
}
-void
-gsk_vulkan_push_constants_set_color (GskVulkanPushConstants *self,
- const GdkRGBA *color)
-{
- self->fragment.color[0] = pow (color->red, 2.2);
- self->fragment.color[1] = pow (color->green, 2.2);
- self->fragment.color[2] = pow (color->blue, 2.2);
- self->fragment.color[3] = color->alpha;
-}
-
void
gsk_vulkan_push_constants_push_vertex (GskVulkanPushConstants *self,
VkCommandBuffer command_buffer,
&self->vertex);
}
+#if 0
void
gsk_vulkan_push_constants_push_fragment (GskVulkanPushConstants *self,
VkCommandBuffer command_buffer,
sizeof (self->fragment),
&self->fragment);
}
+#endif
uint32_t
gst_vulkan_push_constants_get_range_count (void)
.stageFlags = VK_SHADER_STAGE_VERTEX_BIT,
.offset = G_STRUCT_OFFSET (GskVulkanPushConstants, vertex),
.size = sizeof (((GskVulkanPushConstants *) 0)->vertex)
+#if 0
},
{
.stageFlags = VK_SHADER_STAGE_FRAGMENT_BIT,
.offset = G_STRUCT_OFFSET (GskVulkanPushConstants, fragment),
.size = sizeof (((GskVulkanPushConstants *) 0)->fragment)
+#endif
}
};
struct {
float mvp[16];
} vertex;
+#if 0
struct {
- float color[4];
} fragment;
+#endif
};
const VkPushConstantRange *
const graphene_matrix_t *mvp);
void gsk_vulkan_push_constants_multiply_mvp (GskVulkanPushConstants *self,
const graphene_matrix_t *transform);
-void gsk_vulkan_push_constants_set_color (GskVulkanPushConstants *self,
- const GdkRGBA *color);
void gsk_vulkan_push_constants_push_vertex (GskVulkanPushConstants *self,
VkCommandBuffer command_buffer,
VkPipelineLayout pipeline_layout);
-void gsk_vulkan_push_constants_push_fragment (GskVulkanPushConstants *self,
- VkCommandBuffer command_buffer,
- VkPipelineLayout pipeline_layout);
G_END_DECLS
GSK_VULKAN_OP_TEXTURE,
GSK_VULKAN_OP_COLOR,
/* GskVulkanOpPushConstants */
- GSK_VULKAN_OP_PUSH_VERTEX_CONSTANTS,
- GSK_VULKAN_OP_PUSH_FRAGMENT_CONSTANTS
+ GSK_VULKAN_OP_PUSH_VERTEX_CONSTANTS
} GskVulkanOpType;
struct _GskVulkanOpRender
break;
case GSK_COLOR_NODE:
- op.type = GSK_VULKAN_OP_PUSH_FRAGMENT_CONSTANTS;
- gsk_vulkan_push_constants_init_copy (&op.constants.constants, constants);
- gsk_vulkan_push_constants_set_color (&op.constants.constants, gsk_color_node_peek_color (node));
- g_array_append_val (self->render_ops, op);
-
op.type = GSK_VULKAN_OP_COLOR;
op.render.pipeline = gsk_vulkan_render_get_pipeline (render, GSK_VULKAN_PIPELINE_COLOR);
g_array_append_val (self->render_ops, op);
gsk_vulkan_push_constants_init (&op.constants.constants, mvp);
g_array_append_val (self->render_ops, op);
- op.type = GSK_VULKAN_OP_PUSH_FRAGMENT_CONSTANTS;
- g_array_append_val (self->render_ops, op);
-
gsk_vulkan_render_pass_add_node (self, render, &op.constants.constants, node);
}
g_assert_not_reached ();
case GSK_VULKAN_OP_COLOR:
case GSK_VULKAN_OP_PUSH_VERTEX_CONSTANTS:
- case GSK_VULKAN_OP_PUSH_FRAGMENT_CONSTANTS:
break;
}
}
default:
g_assert_not_reached ();
case GSK_VULKAN_OP_PUSH_VERTEX_CONSTANTS:
- case GSK_VULKAN_OP_PUSH_FRAGMENT_CONSTANTS:
continue;
}
}
default:
g_assert_not_reached ();
case GSK_VULKAN_OP_PUSH_VERTEX_CONSTANTS:
- case GSK_VULKAN_OP_PUSH_FRAGMENT_CONSTANTS:
continue;
}
g_assert_not_reached ();
case GSK_VULKAN_OP_COLOR:
case GSK_VULKAN_OP_PUSH_VERTEX_CONSTANTS:
- case GSK_VULKAN_OP_PUSH_FRAGMENT_CONSTANTS:
break;
}
}
gsk_vulkan_pipeline_layout_get_pipeline_layout (layout));
break;
- case GSK_VULKAN_OP_PUSH_FRAGMENT_CONSTANTS:
- gsk_vulkan_push_constants_push_fragment (&op->constants.constants,
- command_buffer,
- gsk_vulkan_pipeline_layout_get_pipeline_layout (layout));
- break;
-
default:
g_assert_not_reached ();
break;